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(54) Method and apparatus for block encryption 



(57) A system for encrypting a plaintext block using 
a block encryption algorithm having a block size smaller 
than that of the plaintext block. The plaintext block is 
transformed into a masked plaintext block using an in- 
vertible transformation optionally dependent on addi- 
tional data and defined such that each bit of the masked 
plaintext block depends on every bit of the original plain- 
text block. A subportion of the masked plaintext block is 
encrypted using the encryption algorithm to generate an 
encrypted portion of the masked plaintext block. A ci- 
phertext block is generated from the thus encrypted por- 
tion of the masked plaintext blockand the remaining por- 
tion of the masked plaintext block. The ciphertext block 
is transmitted to a data recipient, who reverses the pro- 



cedure to recover the original plaintext block. Since the 
entire masked plaintext block is necessary to recon- 
struct the original plaintext block and since the encrypt- 
ed portion cannot be derived from the remaining portion, 
the remaining portion of the masked plaintext block may 
be transmitted to the recipient in unencrypted form. To 
thwart certain cryptanalytic attacks, either the plaintext 
block or the optional additional data is uniquely modified 
for each encryption of a plaintext block, using an incre- 
menting counter, time stamp, random number or other 
mechanism. In an exemplary embodiment, an elliptic 
curve algorithm having a block size on the order of 160 
bits is used to encrypt a 51 2-bit block containing a sym- 
metric encryption key 
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Description 

This invention relates to a block encryption system 
and more particularly to a method and apparatus for en- 
crypting a long plaintext block using an encryption pro- 
cedure intended for relatively short blocks. 

Encryption schemes fall into two general catego- 
ries: symmetric encryption systems and asymmetric en- 
cryption systems. In symmetric encryption systems, 
such as those conforming to the Data Encryption Stand- 
ard (DES), the same key is used by the originator to en- 
crypt data (i.e., convert plaintext to ciphertext) and by 
the recipient to decrypt the same data (i.e., convert ci- 
phertext back to ciphertext). Symmetric encryption 
schemes can often be implemented very efficiently, but 
suffer the disadvantage of requiring the prior exchange 
of encryption keys over a secure communications chan- 
nel. 

Asymmetric encryption systems, or public key en- 
cryption systems as they are usually called, use one key 
to encrypt data while using another key to decrypt the 
same data. In a public key encryption system, an intend- 
ed recipient of data generates a key pair consisting of 
an encryption key, which is made public, and a corre- 
sponding decryption key, which is kept private and not 
shared with others. The keys are generated in such a 
manner that the private key cannot be derived from 
knowledge of the corresponding public key; hence, only 
the intended recipient having the private key can decrypt 
a ciphertext message generated using the public key. 
An important advantage public key encryption systems 
have over symmetric systems is that they do not require 
the exchange of secret key information; two parties can 
establish a secure two-way communication by exchang- 
ing public keys that they have generated. For this rea- 
son, asymmetric encryption systems are often used for 
the secret key exchange required in symmetric encryp- 
tion systems. 

Perhaps the most well-known public key encryption 
system is the RSA encryption system, named after its 
originators and described in R. L. Rivest et al., "A Meth- 
od for Obtaining Digital Signatures and Public-Key 
Cryptosystems", Communications of the ACM , vol. 21, 
no. 2, pp. 1 20-1 26 (1 978). RSA encryption systems typ- 
ically have encryption blocks on the order of 512 bits 
and can be computationally quite intensive. Recently, 
however, so-called elliptic curve systems have been de- 
scribed in such references as N. Koblitz, "Elliptic Curve 
Cryptosystems", Mathematics of Computation , vol. 48, 
no. 177, pp. 203-209 (Jan. 1987), and A. Menezes, El- 
liptic Curve Public Key Cryptosystems (1993). Like the 
RSA encryption system, elliptic curve systems are pub- 
lic key systems with public encryption keys and private 
decryption keys. Elliptic curve systems typically have 
relatively short key and encryption block sizes, on the 
order of 160 bits for each, but have a cryptographic 
strength that is comparable to that of longer-block RSA 
encryption systems. Elliptic curve systems thus repre- 



sent an attractive combination of cryptographic strength 
and computational efficiency. 

Since elliptic curve encryption systems are public 
key systems, one use of such systems might be to dis- 
s tribute keys. Thus, user A might use a public elliptic 
curve key to encrypt a symmetric key (e.g., a DES key) 
for distribution to user B. But a problem arises, since the 
symmetric key is normally contained in a key block (e. 
g., a 51 2-bit block) which is much longer than the elliptic 
10 curve encryption block, which, as noted above, may be 
on the order of only 1 60 bits. Although the key block can 
be divided into multiple encryption blocks of sufficiently 
small size, the additional encryption operations required 
for the individual encryption blocks vitiate to some extent 
15 the natural advantages of elliptic curve systems in terms 
of their computational efficiency. What is needed is a 
method of key encryption that can be used with an el- 
liptic curve algorithm which will permit a large key block 
to be encrypted with a secret elliptic curve key of much 
20 shorter length. 

According to a first aspect of the present invention 
there is provided a method of encrypting a plaintext 
block using a block encryption procedure, said method 
comprising the steps of: 

25 

generating a masked plaintext block as a function 
of said plaintext block and additional data using a 
predetermined invertible transformation defined 
such that the original plaintext block is recoverable 
30 from said masked plaintext block and optional ad- 
ditional data; and 

encrypting at least a subportion of said masked 
plaintext block using said encryption procedure to 
generate a ciphertext block. 

35 

According to a second aspect of the present inven- 
tion there is provided a method of encrypting a plaintext 
data block using a block encryption procedure having a 
block size smaller than that of said plaintext block, said 
40 method comprising the steps of: 

transforming said plaintext block into a masked 
plaintext block using a predetermined invertible 
transformation defined such that each bit of said 
45 masked plaintext block depends on every bit of the 
original plaintext block; 

encrypting a subportion of said masked plaintext 
block having said block size using said encryption 
procedure to generate an encrypted portion of said 
so masked plaintext block; and generating a ciphertext 
block from said encrypted portion of said masked 
plaintext block and the remaining portion of said 
masked plaintext block. 

55 According to a third aspect of the present invention 
there is provided a method of encrypting a plaintext 
block using a block encryption procedure, said method 
comprising the steps of: 
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generating a masked plaintext block as a function 
of said plaintext block and optional additional data 
using a predetermined invertible transformation de- 
fined such that the original plaintext block is recov- 
erable from said masked plaintext block and option- 
al additional data; 

encrypting at least a subportion of said masked 
plaintext block using said encryption procedure to 
generate a ciphertext block; and 
uniquely modifying at least one of said plaintext 
block and said optional additional data prior to gen- 
eration of said masked plaintext block for each en- 
cryption of a plaintext block. 

According to a fourth aspect of the present invention 
there is provided an apparatus for encrypting a plaintext 
data block using a block encryption procedure having a 
block size smaller than that of said plaintext block, said 
apparatus comprising: 

means for transforming said plaintext block into a 
masked plaintext block using a predetermined in- 
vertible transformation defined such that each bit of 
said masked plaintext block depends on every bit 
of the original plaintext block; 
means for encrypting a subportion of said masked 
plaintext block having said block size using said en- 
cryption procedure to generate an encrypted por- 
tion of said masked plaintext block; and 
means for generating a ciphertext block from said 
encrypted portion of said masked plaintext block 
and the remaining portion of said masked plaintext 
block. 

According to a fifth aspect of the present invention 
there is provided an apparatus for encrypting a plaintext 
block using a block encryption procedure, said appara- 
tus comprising: 

means for generating a masked plaintext block as 
a function of said plaintext block and optional addi- 
tional data using a predetermined invertible trans- 
formation defined such that the original plaintext 
block is recoverable from said masked plaintext 
block and optional additional data; and 
means for encrypting at least a subportion of said 
masked plaintext block using said encryption pro- 
cedure to generate a ciphertext block; and 
means for uniquely modifying at least one of said 
plaintext block and said optional additional data pri- 
or to generation of said masked plaintext block for 
each encryption of a plaintext block. 

According to a sixth aspect of the present invention 
there is provided a program storage device readable by 
a machine, tangibly embodying a program of instruc- 
tions executable by the machine to perform method 
steps for encrypting a plaintext data block using a block 



encryption procedure having a block size smaller than 
that of said plaintext block, said method steps compris- 
ing: 

s transforming said plaintext block into a masked 
plaintext block using a predetermined invertible 
transformation defined such that each bit of said 
masked plaintext block depends on every bit of the 
original plaintext block; 
10 encrypting a subportion of said masked plaintext 
block having said block size using said encryption 
procedure to generate an encrypted portion of said 
masked plaintext block; and 
generating a ciphertext block from said encrypted 
15 portion of said masked plaintext block and the re- 
maining portion of said masked plaintext block. 

According to a seventh aspect of the present inven- 
tion there is provided a program storage device reada- 
20 ble by a machine, tangibly embodying a program of in- 
structions executable by the machine to perform method 
steps for encrypting a plaintext block using a block en- 
cryption procedure, said method steps comprising: 

25 generating a masked plaintext block as a function 
of said plaintext block and optional additional data 
using a predetermined invertible transformation de- 
fined such that the original plaintext block is recov- 
erable from said masked plaintext block and option- 
ee al additional data; and 

encrypting at least a subportion of said masked 
plaintext block using said encryption procedure to 
generate a ciphertext block; and 
uniquely modifying at least one of said plaintext 
35 block and said optional additional data prior to gen- 
eration of said masked plaintext block for each en- 
cryption of a plaintext block. 

One aspect of the present embodiment contem- 

40 plates a system for encrypting a plaintext block (such as 
a key block) using a block encryption algorithm (such as 
an elliptic curve algorithm) having a block size smaller 
than that of the plaintext block. The plaintext block is 
transformed into a masked plaintext block using an in- 

45 vertible transformation optionally dependent on addi- 
tional data outside the plaintext block. The additional da- 
ta may comprise control information, a control vector or 
other information available to the recipient and not re- 
quiring encryption. The transformation is defined such 

50 that (1) the original plaintext block is recoverable from 
the masked key block and optional additional informa- 
tion and (2) each bit of the masked plaintext block de- 
pends on every bit of the original plaintext block. A sub- 
portion of the masked plaintext block is encrypted using 

55 the encryption algorithm to generate an encrypted por- 
tion of the masked plaintext block. A ciphertext block is 
generated from the thus encrypted portion of the 
masked plaintext block and the remaining portion of the 
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masked plaintext block. The ciphertext block is transmit- 
ted to a recipient, who reverses the procedure to recover 
the original plaintext block. 

The encryption procedure may comprise an asym- 
metric encryption procedure having a public encryption 
key and a private decryption key. The encryption proce- 
dure may comprise an elliptic curve procedure. 

Since the entire masked plaintext block is neces- 
sary to reconstruct the original plaintext block and since 
the encrypted portion cannot be derived from the re- 
maining portion, the remaining portion of the masked 
plaintext block may be transmitted to the recipient in un- 
encrypted form. Therefore a long key block may be en- 
crypted with a short encryption key. In an exemplary em- 
bodiment, an elliptic curve algorithm having a block size 
on the order of 1 60 bits is used to encrypt a 51 2-bit block 
containing a symmetric encryption key. 

The plain text block may comprise first and second 
parts and the transforming step may comprise the steps 
of generating a first mask value from said second part 
using a first transformation; 

combining said first mask value with said first part 
to generate an intermediate-stage first part; 
generating a second mask value from said interme- 
diate-stage first part using a second transformation; 
combining said second mask value with said sec- 
ond part to generate a masked second part; 
generating a third mask value from said masked 
second part using a third transformation; and 
combining said third mask value with said interme- 
diate-stage first part to generate a masked first part, 
one of said masked parts being used to generate a 
first part of said masked plaintext block, the other 
of said masked parts being used to generate a sec- 
ond part of said masked plaintext block. 

The mask values may be generated using one-way 
functions. The combining steps may be performed by 
combining n-bit blocks using modula addition or bitwise 
modula 2 addition. 

In another aspect, either the plaintext block or the 
additional data on which the transformation is optionally 
dependent is uniquely modified for each encryption of a 
plaintext block, using an incrementing counter, time 
stamp, random number or other mechanism to thwart 
certain cryptanalytic attacks. 

In order to promote this and other aspects of the 
invention there is described, by way of example only, at 
least one embodiment of the present invention with ref- 
erence to the accompanying drawings. 

Fig. 1 is a schematic block diagram of the encryp- 
tion procedure of the present invention. 

Fig. 2 is a schematic block diagram of the masking 
procedure used in the encryption procedure shown in 
Fig. 1. 

Fig. 3 is a schematic block diagram of a first gener- 
ator function used in the masking procedure shown in 



Fig. 2. 

Fig. 4 is a schematic blockdiagram of a second gen- 
erator function used in the masking procedure shown in 
Fig. 2. 

5 Fig. 5 is a schematic block diagram of the format of 

the key block. 

Fig. 6 is a schematic block diagram of the decryp- 
tion procedure of the present invention. 

Fig. 7 is a schematic block diagram of the unmask- 
10 jng procedure used in the decryption procedure shown 
in Fig. 6. 

Fig. 8 is a schematic block diagram of a modified 
masking procedure using additional data outside the 
key block. 

15 

Description of the Preferred Embodiments 

Fig. 1 illustrates the general encryption procedure 
100 of the present invention. Depending on the particu- 

20 |ar implementation, the functional blocks depicted in Fig. 
1 and elsewhere may represent hardware elements, 
software code, or some combination of the two. As is 
usual, by "software code" is meant a program of instruc- 
tions residing on a machine-readable program storage 

25 device (such as a magnetic or optical disk) that are ex- 
ecutable by a machine (such as a server or a client work- 
station) to perform the described method steps. The ma- 
chine and program storage devices of such a software 
implementation are entirely conventional and are hence 

30 not shown. 

Encryption procedure 100 has as its input a long 
plaintext block such as the key block 110 shown. In gen- 
eral, key block 110 may consist of any desired data, 
such as a symmetric encryption key. However, key block 

35 no should contain a secret value (e.g., a secret DES 
key or a secret random number) of sufficient length to 
prevent exhaustion and to prevent an adversary from 
inverting the masking procedure to be described. For 
the sake of discussion, it will be assumed that the secret 

40 value has enough independent bits to prevent exhaus- 
tion attacks to find its value, e.g., 128 bits. The present 
invention does not contemplate any particular number 
of bits, though, for the secret value. 

The key block 110 may also contain certain fixed 

45 bits that may be required by the encryption process (e. 
g., setting a high order bit to zero) or required by the 
parsing algorithm (e.g., use of a delimiter byte). Howev- 
er, the key block 110 should preferably also contain oth- 
er fixed or predictable bits used for non-malleability; 

so these bits can be used to verify that the key block has 
been properly recovered. 

Fig. 5 shows a possible format for key block 110. 
Key block 110 contains a first field 501 with fixed infor- 
mation to verify the recovery process, a second field 502 

55 containing the symmetric encryption key or other secret 
information being conveyed to the recipient, and an op- 
tional third field 503 containing a count from a counter 
504 that is incremented (505) for each encryption of a 
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plaintext block. 

Count field 503 ensures that the key block 110 is 
unique for each encryption of a plaintext block. Although 
a randomly generated number could be used for a sim- 
ilar purpose, using a count deterministically avoids iden- 
tical key blocks 110, whereas a random number only 
provides a probability of avoiding identical key blocks. 
As an alternative to having a count in the key block 110 
itself, a count may also be inserted into an additional 
data field, outside the key block, on which the masking 
transformation is optionally dependent, as described 
below. 

Referring again to Fig. 1, in encryption procedure 
100 key block 110 is first "masked", or transformed into 
a masked key block 1 30 of the same size using a mask- 
ing procedure 120. Masking procedure 120, the details 
of which are described below, is an invertible transfor- 
mation defined to have the following cryptographic prop- 
erties: 

1 . Each bit in the masked key block 1 30 is a function 
of each and every bit in the key block 1 1 0 (i.e. , there 
is strong intersymbol independence). 

2. No bit in the key block 110 can be determined 
unless every bit in the masked key block 130 is 
known or available (excepting the case where the 
adversary is able to exhaust on the unknown bits of 
the masked key block). 

The masked key block 1 30 produced by a masking 
procedure 120 having these properties can be protected 
by encrypting any subportion of it, as long as the key is 
long enough to deter an exhaustion-type attack. 

A subportion 131 of the masked key block 130 is 
then encrypted, using a encryption procedure 140 hav- 
ing an encryption key 1 41 , to generate an encrypted por- 
tion 151 of aciphertextblock 150. Preferably, encryption 
procedure 140 is a public key procedure, such as an 
elliptic curve procedure having a key (and encryption 
block) size on the order of 160 bits. The particulars of 
the elliptic curve procedure used form no part of the 
present invention, but are described in the references 
cited above. While the elliptic curve procedure is highly 
preferred because of its high cryptographic strength rel- 
ative to its block size, in general any other public key 
procedure or even a private key procedure such as DES 
may be used instead for encryption procedure 140. 

The remaining portion 152 of the ciphertext block 
may simply be taken from the corresponding portion 1 32 
of the masked plaintext block 1 30, without encrypting it. 
Alternatively, all or part of the remaining portion 132 of 
the masked key block 130 may be encrypted as one or 
more blocks or subportions, using one or more keys and 
one or more encryption algorithms. The same data may 
also be multiply encrypted along an encryption pipeline, 
again using one or more keys and one or more encryp- 
tion algorithms. 



Fig. 2 shows the masking procedure 120. The 
masking procedure first divides the key block 1 1 0 into a 
first part 202 (part A) and a second part 204 (part B). 
Although Part A is shown to the left of part B in the figure, 

s any other scheme for assigning bits to the two parts may 
be used as well; the order and location of the bits is not 
important. Parts A (202) and B (204) may be of equal 
length or of different lengths. There may be security ad- 
vantages, however, to having parts 202, 204 of equal or 

10 near equal length. 

It is assumed that at least one of parts 202, 204 con- 
tains a secret value, such as a secret key or a secret 
random number. However, the secret value may also be 
divided with a portion in part 202 and a portion in part 

15 204. 

In general, masking procedure 120 comprises the 
following steps: 

1 . Masking part A (202) with part B (204) to generate 
20 an intermediate-stage part A (212). 

2. Masking part B (204) with the intermediate-stage 
part A (212) to generate a masked part B (220). 

25 3. Masking the intermediate-stage part A (212) with 
the masked part B (220) to generate a final masked 
part A (228). 

4. Optionally, additional iterations of masking (not 
30 shown) if desired or needed. 

Three iterations of masking are needed to make 
each bit in the masked key block 1 30 a function of each 
bit in the (unmasked) key block 110. Three iterations of 
35 masking, appropriately performed, should also be suffi- 
cient to make each bit in the masked key block 1 30 de- 
pendent on each bit in the original key block 110. This 
achieves complete intersymbol dependence. 

The masking procedure will now be described in de- 
40 tail. The masking procedure 1 20 calculates a first mask 
value 208 (mask 1) on part B (204) using a first gener- 
ator function (G1) 206. The length of mask 1 (208) is 
equal to the length of part A (202). 

Mask 1 (208) is then combined (210) with part A 
45 (202) to produce an intermediate-stage part A (212). 
The combining operation 210 may be an Exclusive-OR 
(XOR) operation, i.e., bitwise modulo 2 addition, as 
shown. More generally, the combining operation 210 
may comprise any invertible operation, such as modulo 
50 addition on n-bit blocks. 

Next, a second mask value 216 (mask 2) is calcu- 
lated on intermediate-stage part A (21 2) using a second 
generator function 214 (G2). The length of mask 2 (21 6) 
is equal to the length of part B (204). Mask 2 (216) is 
55 Exclusive-ORed (218) with part B (204) to produce a 
masked part B (220). 

Finally, a third mask value 224 (mask 3) is calculat- 
ed on the masked part B (204) using a third generator 
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function 222 (G3). The length of mask 3 (224) is equal 
to the length of part A (202). Mask 3 (224) is Exclusive- 
ORed (226) with the intermediate-stage part A (212) to 
produce a final masked part A (228). 

Each of generator functions G1-G3 is a crypto- 
graphic one-way function that calculates an n-bit output 
value from an m-bit input value, where m and n are input 
variables to the generator function. As is conventional 
in cryptography, by "one-way" function is meant a func- 
tion whose inverse is computationally infeasible to cal- 
culate for almost any output value of the function. One 
possible implementation of generator functions G1-G3 
would be to employ a strong cryptographic hash function 
H, such as the NIST Secure Hash Algorithm Revision 
One (SHA-1), described in FIPS Publication 180-1, Se- 
cure Hash Standard (SHS); the RSA Message Digest 
algorithm 5 (MD5), described in R. L. Rivest, "The MD5 
Message Digest Algorithm", RFC 1321, Apr. 1992; or 
the IBM Modification Detection Code algorithm (MDC- 
2/4), described in Brachtl et al. U.S. Patent 4,908,861. 

In the example below, suppose that MD5, which 
produces a 128-bit hash value, is used for the hash func- 
tion H. As a simplifying assumption, suppose that the 
lengths of parts 202 and 204 are multiples of 128 bits 
(16 bytes). And suppose, for the sake of argument, that 
part A (202) consists of three 16-byte blocks and part B 
(204) consists of two 16-byte blocks. 

Referring to Fig. 3, the first mask value 208 (mask 
1) is calculated with function G1 (206) as follows: 

1 . A unique value 302 (value 1 ) is concatenated with 
part B (204), and the resulting value is hashed with 
H (308) to produce a 128-bit value 314 (X1). 

2. A unique value 304 (value 2) is concatenated with 
part B (204), and the resulting value is hashed with 
H (310) to produce a 128-bit value 316 (X2). 

3. A unique value 306 (value 3) is concatenated with 
part B (204), and the resulting value is hashed with 
H (312) to produce a 128-bit value 318 (X3). 

Mask 1 (208) is defined as the concatenation of val- 
ues 314, 316, 318 (X1-X3). The length of mask 1 (208) 
is 3 X 16 = 48 bytes, as is the length of part A (202), 
with which it is Exclusive-ORed. 

Referring to Fig. 4, the second mask value 216 
(mask 2) is calculated with function G2 (214) as follows: 

1 . A unique value 402 (value 4) is concatenated with 
the intermediate-stage part A (212), and the result- 
ing value is hashed with H (406) to produce a 
128-bit value 410 (X4). 

2. A unique value 404 (value 5) is concatenated with 
the intermediate-stage part A (212), and the result- 
ing value is hashed with H (408) to produce a 
128-bit value 412 (X5). 



Mask 2 (21 6) is defined as the concatenation of val- 
ues 410, 412 (X4-X5). The length of mask 2 (216) is 2 
X 16 = 32 bytes, as is the length of part B (204), with 
which it is Exclusive-ORed. 

s In the embodiment shown, function G3 (222) is 

identical to function G1 (206), the only difference be- 
tween the two being that function G3 receives its input 
from the masked part B (220) instead of the unmasked 
part B (204). This is merely for efficiency of implemen- 
ts' tation, however, and in general G3 may differ from G1 . 
Also, function G2 differs from functions G1 and G3 only 
because parts 202 and 204 are of different lengths. If 
the two parts were of the same length, then all three 
functions G1-G3 could be identical. 

15 Values 302-306 and 402-404, though differing from 
one another, may remain the same for each invocation 
of functions G1-G3. Alternatively, each of these values 
may be altered for each successive invocation of the 
generator functions, using an incrementing counter or 

20 other suitable mechanism. 

If the length of part 202 or 204 is not a multiple of 
the length of the hash function H (16 bytes in the above 
example), a mask value is calculated which is (1) a mul- 
tiple of length of the hash function H and (2) longer than 

25 the data it is intended to mask. In that case, a subportion 
of the mask is Exclusive-ORed with the input data. It 
may also be necessary to pad the input data prior to 
hashing the data. But this does not materially affect the 
design of the generator function. 

30 Fig. 6 shows the procedure 600 used to recover the 
original key block from the ciphertext block 150. Proce- 
dure 600 decrypts the encrypted portion 151 of cipher- 
text block 150, using a decryption procedure 610, to 
generate the first portion 621 of a regenerated masked 

35 key block 620. Decryption procedure 610 is simply the 
inverse of encryption procedure 140. If encryption pro- 
cedure 140 is a public key procedure having a public 
encryption key 1 41 , decryption procedure 610 has a cor- 
responding secret decryption key 611 known only to the 

40 recipient. If encryption procedure 140 is a symmetric 
procedure, decryption key 611 is the same as (secret) 
encryption key 1 41 . The remaining portion 622 of regen- 
erated masked key block 620 is simply taken from the 
remaining portion 152 of the ciphertext block 150, with- 

45 out alteration. An unmasking procedure 630 then trans- 
forms the regenerated masked key block 620 into an 
unmasked key block 640 that should match the original 
key block 110. 

Fig. 7 shows the unmasking procedure 630, which 

50 is simply the inverse of masking procedure 1 20. Proce- 
dure 630 first divides the regenerated masked key block 
620 into masked parts A (702) and B (704) correspond- 
ing in length to parts 202 and 204 (Fig. 2), respectively. 
Procedure 630 then regenerates mask 3 (708) from 

55 masked part B (704) using generator function G3 (706). 
Mask 3 (708) is then combined (710) with masked part 
A (702) to regenerate intermediate-stage part A (712). 
Next, mask 2 (716) is generated from intermediate- 
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stage part A (712) using generator function G2 (714). 
Mask 2 (716) is combined (718) with masked part B 
(704) to regenerate the original part B (720). Finally, 
mask 1 (724) is generated from the original part B (720) 
using generator function G1 (722). Mask 1 (724) is com- 
bined (726) with intermediate-stage part A (712) to pro- 
duce a final unmasked part A (728). 

Combining operations 710, 718 and 726 are con- 
structed so as to reverse operations 226, 218 and 210, 
respectively, of the masking procedure 120. In the em- 
bodiment shown, where the combining operations in the 
masking procedure 120 are XOR operations, the re- 
verse combining operations 710, 718 and 726 are also 
XOR operations. 

If, as in the present embodiment, functions G1 and 
G3 are the same, the unmasking procedure 630 (Figs. 
6-7) is identical to the masking procedure 120 (Figs. 
1-4); i.e., applying the masking procedure 120 twice 
yields the original output. However, this is a special case 
and in general masking procedure 120 may differ from 
the inverse unmasking procedure 630. 

There may be situations were one has data, such 
as control information, an initializing vector or a count, 
that one desires to associate or couple to the key but 
does not wish to keep in the key block itself. This can 
be accomplished by appending this data or a hash of 
this data to one of the parts into which the plaintext block 
is divided and calculating a mask value on the extended 
part. Otherwise, the method is as described above. 

Fig. 8 shows a modified masking procedure 120' in 
which a modified mask 1 (208 1 ) is calculated by concate- 
nating part B (204) with an additional data field 801 
("other data") to generate an extended part B (204'). Ad- 
ditional data field 801 is based upon control information, 
an initializing vector, a count that is incremented for each 
successive encryption, or other information that is avail- 
able to or can be created by the recipient. The additional 
data field 801 may contain the information in unmodified 
form or may be based on a hash function of such infor- 
mation. Although the additional data field 801 is shown 
as being appended to the right of part B (204), it may 
also be appended to the left of part B, as may be pref- 
erable in many cases. A modified function G1 (206 1 ) re- 
sponsive to the entire extended part B (204 1 ) generates 
a modified mask 1 (208 1 ), which is combined (210) with 
part A (204) to generate a modified intermediate-stage 
part A (212'). 

The remainder of the modified masking procedure 
120' is identical to the masking procedure 120 depicted 
in Fig. 2 (except for receiving modified inputs) and hence 
is not shown. The unmasking procedure corresponding 
to the modified masking procedure 1 20' is similar to un- 
masking procedure 630, but with appropriate modifica- 
tions to take account of the additional data field 801 . 

In the modified masking procedure 120' shown in 
Fig. 8, it is the first masking stage (masking part A with 
part B) that is modified to make the masking value de- 
pendent on the additional data field 801 . Alternatively or 



additionally, however, either or both of the two subse- 
quent masking stages could be modified to use the ad- 
ditional data field 801 . Thus, either or both of generator 
functions G2 (214) and G3 (222) could be modified to 
s depend on an extended key block part created by con- 
catenating the original block part with the additional data 
field. In the former case, the additional data field 801 
would be concatenated with part A rather than with part 
B to provide an input to function G2. 

This modification has the advantage that the 
masked key block 130 is now a function of the original 
key block 110 and also the extra data (or hash of such 
data) in additional data field 801. But the extra data is 
not part of the key block 110 itself and so does not be- 
come masked. 

As already noted, either key block 110 or the addi- 
tional data field 801 (or both) should be unique for each 
encryption of a plaintext block. This may be accom- 
plished by inserting a unique count in the key block 110 
or additional data field 801, or by using a time stamp, 
random number or other mechanism as described 
above. 

In summary there is described a system for encrypt- 
ing a plaintext block using a block encryption algorithm 
having a block size smaller than that of the plaintext 
block. The plaintext block is transformed into a masked 
plaintext block using an invertible transformation option- 
ally dependent on additional data and defined such that 
each bit of the masked plaintext block depends on every 
bit of the original plaintext block. A subportion of the 
masked plaintext block is encrypted using the encryp- 
tion algorithm to generate an encrypted portion of the 
masked plaintext block. Aciphertext block is generated 
from the thus encrypted portion of the masked plaintext 
block and the remaining portion of the masked plaintext 
block. The ciphertext block is transmitted to a data re- 
cipient, who reverses the procedure to recover the orig- 
inal plaintext block. Since the entire masked plaintext 
block is necessary to reconstruct the original plaintext 
block and since the encrypted portion cannot be derived 
from the remaining portion, the remaining portion of the 
masked plaintext block may be transmitted to the recip- 
ient in unencrypted form. To thwart certain cryptanalytic 
attacks, either the plaintext block or the optional addi- 
tional data is uniquely modified for each encryption of a 
plaintext block, using an incrementing counter, time 
stamp, random number or other mechanism. In an ex- 
emplary embodiment, an elliptic curve algorithm having 
a block size on the order of 160 bits is used to encrypt 
a 512-bit block containing a symmetric encryption key. 



Claims 

55 1. A method of encrypting a plaintext block using a 
block encryption procedure, said method compris- 
ing the steps of: 
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generating a masked plaintext block as a func- 
tion of said plaintext block and additional data 
using a predetermined invertible transforma- 
tion defined such that the original plaintext 
block is recoverable from said masked plaintext 
block and optional additional data; and 

encrypting at least a subportion of said masked 
plaintext block using said encryption procedure 
to generate a ciphertext block. 

2. A method of encrypting a plaintext data block using 
a block encryption procedure having a block size 
smaller than that of said plaintext block, said meth- 
od comprising the steps of: 

transforming said plaintext block into a masked 
plaintext block using a predetermined invertible 
transformation defined such that each bit of 
said masked plaintext block depends on every 
bit of the original plaintext block; 

encrypting a subportion of said masked plain- 
text block having said block size using said en- 
cryption procedure to generate an encrypted 
portion of said masked plaintext block; and 

generating a ciphertext blockf rom said encrypt- 
ed portion of said masked plaintext block and 
the remaining portion of said masked plaintext 
block. 

3. The method of Claims 1 or 2, comprising the further 
step of transmitting said ciphertext block to a recip- 
ient. 

4. The method of Claims 2 or 3 wherein said ciphertext 
block is either: 

(a) generated by encrypting the remaining por- 
tion of said masked plaintext block; or 

(b) generated without encrypting the remaining 
portion of said masked plaintext block. 

5. The method of Claim 4 wherein said remaining por- 
tion of said masked block is encrypted using an en- 
cryption procedure other than the encryption proce- 
dure used to encrypt said subportion of said 
masked plaintext block. 

6. The method of Claims 2 to 5, comprising the further 
step of recovering the original plaintext block from 
said ciphertext block. 

7. The method of Claim 6 wherein said recovering step 
comprises the steps of: 



regenerating said masked plaintext block from 
said ciphertext block, said regenerating step in- 
cluding the step of decrypting said encrypted 
portion of said masked plaintext block; and 

5 

regenerating the original plaintext block from 
the regenerated masked plaintext block by in- 
verting said predetermined transformation. 

10 8. The method of Claims 2 to 7 wherein said plaintext 
block comprises first and second parts, said trans- 
forming step comprising the steps of: 

masking said first part with said second part to 
15 generate an intermediate-stage first part; 

masking said second part with said intermedi- 
ate-stage first part to generate a masked sec- 
ond part; and 

20 

masking said intermediate-stage first part with 
said masked second part to generate a masked 
first part, one of said masked parts being used 
to generate a first part of said masked plaintext 
25 block, the other of said masked parts being 

used to generate a second part of said masked 
plaintext block. 

9. The method of Claim 8 wherein at least one of said 
30 masking steps comprises the steps of: 

concatenating one of said parts with additional 
data outside of said key block to generate an 
extended part; and 

35 

masking the other of said parts with said ex- 
tended part. 

10. The method of Claim 8 or 9 wherein said masked 
40 first part forms said first part of said masked plain- 
text block and said masked second part forms said 
second part of said masked plaintext block. 

11. The method of any of Claims 2 to 7 wherein said 
45 plaintext block comprises first and second parts, 

said transforming step comprising the steps of: 

generating a first mask value from said second 
part using a first transformation; 

50 

combining said first mask value with said first 
part to generate an intermediate-stage first 
part; 

55 generating a second mask value from said in- 

termediate-stage first part using a second 
transformation; 
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combining said second mask value with said 
second part to generate a masked second part; 

generating a third mask value from said 
masked second part using a third transforma- s 
tion; and 

combining said third mask value with said inter- 
mediate-stage first part to generate a masked 
first part, one of said masked parts being used 10 
to generate a first part of said masked plaintext 
block, the other of said masked parts being 
used to generate a second part of said masked 
plaintext block. 

15 

12. The method of any of Claims 2 to 11 wherein said 
masked plaintext block is generated as a function 
of said plaintext block and optional additional data, 
said method comprising the further step of uniquely 
modifying at least one of said plaintext block and 20 
optional additional data for each encryption of a 
plaintext block, said transforming step being per- 
formed on said modified plaintext block. 

13. A method of encrypting a plaintext block using a 25 
block encryption procedure, said method compris- 
ing the steps of: 

generating a masked plaintext block as a func- 
tion of said plaintext block and optional addi- 30 
tional data using a predetermined invertible 
transformation defined such that the original 
plaintext block is recoverable from said masked 
plaintext block and optional additional data; 

35 

encrypting at least a subportion of said masked 
plaintext block using said encryption procedure 
to generate a ciphertext block; and 

uniquely modifying at least one of said plaintext 40 
block and said optional additional data prior to 
generation of said masked plaintext block for 
each encryption of a plaintext block. 

14. The method of Claim 1 3 wherein at least one of said 45 
plaintext block and said optional additional data 
contains one or more of the following features: 

a) are uniquely modified prior to generation of 
said masked plaintext blockfor each encryption so 
of a plaintext block. 

b) contains a count that is incremented for each 
encryption of a plaintext block; 

55 

c) contains a time stamp that is different for 
each encryption of a plaintext block; and 



d) contains a value that is randomly generated 
for each encryption of a plaintext block. 

15. Apparatus for encrypting a plaintext data block us- 
ing a block encryption procedure having a block 
size smaller than that of said plaintext block, said 
apparatus comprising: 

means for transforming said plaintext block into 
a masked plaintext block using a predeter- 
mined invertible transformation defined such 
that each bit of said masked plaintext block de- 
pends on every bit of the original plaintext 
block; 

means for encrypting a subportion of said 
masked plaintext block having said block size 
using said encryption procedure to generate an 
encrypted portion of said masked plaintext 
block; and 

means for generating a ciphertext block from 
said encrypted portion of said masked plaintext 
block and the remaining portion of said masked 
plaintext block. 

16. Apparatus for encrypting a plaintext block using a 
block encryption procedure, said apparatus com- 
prising: 

means for generating a masked plaintext block 
as a function of said plaintext block and optional 
additional data using a predetermined inverti- 
ble transformation defined such that the origi- 
nal plaintext block is recoverable from said 
masked plaintext block and optional additional 
data; and 

means for encrypting at least a subportion of 
said masked plaintext block using said encryp- 
tion procedure to generate a ciphertext block; 
and 

means for uniquely modifying at least one of 
said plaintext block and said optional additional 
data prior to generation of said masked plain- 
text block for each encryption of a plaintext 
block. 

17. A program storage device readable by a machine, 
tangibly embodying a program of instructions exe- 
cutable by the machine to perform method steps for 
encrypting a plaintext data block using a block en- 
cryption procedure having a block size smaller than 
that of said plaintext block, said method steps com- 
prising: 

transforming said plaintext block into a masked 
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plaintext block using a predetermined invertible 
transformation defined such that each bit of 
said masked plaintext block depends on every 
bit of the original plaintext block; 

5 

encrypting a subportion of said masked plain- 
text block having said block size using said en- 
cryption procedure to generate an encrypted 
portion of said masked plaintext block; and 

10 

generating a ciphertext blockf rom said encrypt- 
ed portion of said masked plaintext block and 
the remaining portion of said masked plaintext 
block. 

15 

18. A program storage device readable by a machine, 
tangibly embodying a program of instructions exe- 
cutable by the machine to perform method steps for 
encrypting a plaintext block using a block encryp- 
tion procedure, said method steps comprising: 20 

generating a masked plaintext block as a func- 
tion of said plaintext block and optional addi- 
tional data using a predetermined invertible 
transformation defined such that the original 25 
plaintext block is recoverable from said masked 
plaintext block and optional additional data; 
and 

encrypting at least a subportion of said masked 30 
plaintext block using said encryption procedure 
to generate a ciphertext block; and 

uniquely modifying at least one of said plaintext 
block and said optional additional data prior to 35 
generation of said masked plaintext block for 
each encryption of a plaintext block. 
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than that of the plaintext block. The plaintext 
block is transformed into a masked plaintext block 
using an invert ible transformation optionally 
dependent on additional data and defined such that 
each bit of the masked plaintext block depends on 
every bit of the original plaintext block . A 
subportion of the masked plaintext block is 
encrypted using the encryption algorithm to 
generate an encrypted portion of the masked 
plaintext block . A ciphertext block is generated 
from the thus encrypted portion of the masked 
plaintext block and the remaining portion of the 
masked plaintext block. The ciphertext block is 
transmitted to a data recipient, who reverses the 
procedure to recover the original plaintext block. 
Since the entire masked plaintext block is 
necessary to reconstruct the original plaintext 
block and since the encrypted portion cannot be 
derived from the remaining portion, the remaining 
portion of the masked plaintext block may be 
transmitted to the recipient in unencrypted form. 
To thwart certain cryptanalyt ic attacks, either 
the plaintext block or the optional additional 
data is uniquely modified for each encryption of a 
plaintext block, using an incrementing counter, 
time stamp, random number or other mechanism. In 
an exemplary embodiment, an elliptic curve 
algorithm having a block size on the order of 160 
bits is used to encrypt a 512-bit block containing 

a symmetric encryption key . 
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